<template>
  <!-- 主体区域 -->
  <section id="app">
    <TodoHeader @add="addTodo" />
    <TodoMain :todos="todos" @del="delTodo" />
    <TodoFooter v-if="todos.length" :todos="todos" @clear="clearTodo" />
  </section>
</template>

<script>
import TodoHeader from './components/TodoHeader.vue'
import TodoMain from './components/TodoMain.vue'
import TodoFooter from './components/TodoFooter.vue'

export default {
  components: {
    TodoHeader,
    TodoMain,
    TodoFooter
  },
  data() {
    return {
      todos: []
    }
  },
  watch: {
    todos: {
      handler(val) {
        localStorage.setItem('todos', JSON.stringify(val))
      },
      deep: true
    }
  },
  created() {
    const tempTodos = [
      { id: 1, text: '学习Vue' },
      { id: 2, text: '学习Javascript' },
      { id: 3, text: '学习HTML' }
    ]
    this.todos = localStorage.getItem('todos') && localStorage.getItem('todos') !== '[]' ? JSON.parse(localStorage.getItem('todos')) : tempTodos
  },
  methods: {
    addTodo(text) {
      this.todos.push({
        id: Math.random(),
        text
      })
    },
    delTodo(id) {
      this.todos = this.todos.filter(item => item.id !== id)
    },
    clearTodo() {
      this.todos = []
    }
  }
}
</script>

<style></style>
